package jianzhioffer;

// 剑指 Offer 63. 股票的最大利润
public class MaxProfit {


    public int maxProfit(int[] prices) {
        int n = prices.length;
        // 表示第n天结束的时候，手中持股状态
        int[][] f = new int[n][2];
        f[0][0] = 0;
        f[0][1] = -prices[0];
        for (int i = 1; i < n; i++) {

            // 表示不持股
            f[i][0] = Math.max(f[i - 1][0], f[i - 1][1] + prices[i]);
            // 表示持股
            f[i][1] = Math.max(f[i - 1][1], -prices[i]);
        }
        return f[n-1][0];
    }
}
